package com.ruoyi.graduate.domain.entity;

import com.baomidou.mybatisplus.annotation.*;
import com.fasterxml.jackson.annotation.JsonFormat;
import io.swagger.annotations.ApiModel;
import io.swagger.annotations.ApiModelProperty;
import lombok.Data;
import org.springframework.format.annotation.DateTimeFormat;

import java.time.LocalDateTime;

/**
 * <p>
 * 社区帖子表实体类（关联《毕设.doc》系统管理-社区管理/用户端社区）
 * </p>
 *
 * @author [开发者名称]
 * @since 2025-11-06
 */
@Data
@ApiModel("社区帖子表")
@TableName("ms_community_post") // 映射数据库表名
public class MsCommunityPost {

    @ApiModelProperty(value = "帖子唯一标识（自增主键）")
    @TableId(type = IdType.AUTO) // 对应数据库AUTO_INCREMENT自增主键
    private Integer postId;

    @ApiModelProperty(value = "帖子标题（必填字段）")
    private String title; // 对应数据库title字段（非空，驼峰自动映射）

    @ApiModelProperty(value = "帖子内容（必填字段）")
    private String content; // 对应数据库content字段（text类型，非空）

    @ApiModelProperty(value = "发帖用户ID（外键，关联ms_sys_user表的user_id）")
    private Long authorId; // 对应数据库author_id字段（外键，非空）

    @ApiModelProperty(value = "帖子状态：0=待审核，1=已发布，2=审核驳回（默认待审核）")
    private Integer postStatus ; // 对应数据库post_status字段，默认值0（与表结构默认值一致）

    @ApiModelProperty(value = "审核管理员ID（外键，关联ms_sys_user表的user_id，可选）")
    private Long auditUserId; // 对应数据库audit_user_id字段（外键，可为null）

    @ApiModelProperty(value = "成品图片路径（单张一条记录，支持多图，必填）")
    private String imgUrl; // 对应数据库img_url字段


    @ApiModelProperty(value = "删除标志（0代表存在 2代表删除）")
    @TableLogic
    private String delFlag;

    @ApiModelProperty(value = "审核时间（可选，审核后填充）")
    @DateTimeFormat(pattern = "yyyy-MM-dd HH:mm:ss")
    @JsonFormat(pattern = "yyyy-MM-dd HH:mm:ss", timezone = "GMT+8")
    private LocalDateTime auditTime; // 对应数据库audit_time字段（datetime类型，可为null）

    @ApiModelProperty(value = "发布时间")
    @DateTimeFormat(pattern = "yyyy-MM-dd HH:mm:ss")
    @JsonFormat(pattern = "yyyy-MM-dd HH:mm:ss", timezone = "GMT+8")
    @TableField(fill = FieldFill.INSERT) // 插入时自动填充（与表结构CURRENT_TIMESTAMP对应）
    private LocalDateTime createTime; // 对应数据库create_time字段（非空，默认当前时间）

}